扩展JavaScript的时候,千万要保留其原来的所有功能
2006-12-24 00:32 Jeffrey Zhao 阅读(3943) 评论(12) 编辑 收藏 举报扩展JavaScript的时候,千万要保留其原来的所有功能,因为不知道别人的代码是否会用到这些。而且一般来说,为了写出兼容更多JS框架的代码,最保险的方法就是用JS的原生功能。然而……
在这个问题上,这次ASP.NET AJAX RC栽跟头了。
不知道大家有没有看过ASP.NET AJAX Library RC对于JavaScript的扩展?在RC的扩展中增加了这么一些代码:
Date._jsParse = Date.parse; ... Date.parse = function Date$parse(value, formats) { ... }
上面的代码将Date.parse的原生实现改成了Date._jsParse函数,而自己重新定义了一个Date.parse方法。这样做的话,把Number、Date、Boolean对象都提供了比较统一的parse功能,并且能够支持各种Format并具有本地化功能,着实是不错的扩展。可惜就是因为改了JavaScript的原生功能,让Google Ads这个被广泛运用的……玩意儿,就这么Break了。
这个问题可是直接涉及到广大人民群众的切身利益,严重影响了人民群众的感情。比如在ASP.NET AJAX论坛,就在抱怨这件事情(http://forums.asp.net/thread/1499508.aspx),不过有问题自然就有人会解决,例如Cyril(一看到这张脸就觉得眼熟,原来我当时的《另一种Atlas Scripts Intellisense的方法以及对比与分析》就是引用了他Blog上的方法)提出了一种解决方案:
Date.__cyril_parse = Date.parse; Date.parse = function(s){ try { return Date.__cyril_parse(s); } catch (e){ var d = Date._jsParse(s); if (d) { return d; } else { throw e; } } }
只要引入上面这段代码即可。这是很容易想到的做法,不过还真的没有比这更简单或更有效的解决方案了:把ASP.NET AJAX的Date.parse扩展再另存起来,再重新写一个Date.parse方法,首先尝试ASP.NET AJAX的扩展,如果失败(幸好如果用户按照原来的使用方式会造成失败),则调用JavaScript的原有功能。问题就这么被解决了,不是吗?
这次ASP.NET AJAX RC的错误很低级,还好只是RC,有问题还不怕。不过,这也不就是RC Release的目的吗?至少现在基本上可以肯定,ASP.NET AJAX正式版里的扩展不会再有这个错误了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端